<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        *{padding: 0;margin: 0;}
        .wrap{
            width: 400px;
            height: 400px;
            background-color: grey;
            margin: 50px;
            overflow: hidden;
        }

        .sub{
            width: 300px;
            height: 300px;
            background-color: orange;
            margin: 50px;
            overflow: hidden;
        }

        .box{
            width: 100px;
            height: 100px;
            background-color:aquamarine;
            margin: 100px;
        }
    </style>
</head>
<body>
    <div class="wrap">
        <div class="sub">
            <div class="box"></div>
        </div>
    </div>
</body>
<script>
    // 事件传播机制(父子元素绑定相同类型的事件)

    // 历史渊源
    // 事件捕获(网景): 从最不特定的元素 到 最特定的元素(事件源), 从外到内
    // 事件冒泡(IE)：从最特定的元素(事件源) 到 最不特定的元素, 从内到外
    // 主流:  事件冒泡

    // 注意: 
    // DOM一级只有事件冒泡,没有事件捕获 
    // 有相同类型的事件才会冒泡, 否则就跳过

    // Element.addEventListener(type,callback,isCapture)   添加事件监听(W3C)
    //     Element    绑定事件的元素
    //     type       绑定事件的类型 (click dblclick keydown keyup)
    //     callback   事件触发时的处理函数
    //     isCapture  是否以事件捕获方式触发事件(默认false => 事件冒泡)



    var wrap = document.querySelector(".wrap");
    var sub = document.querySelector(".sub");
    var box = document.querySelector(".box");

    // 事件冒泡
    // wrap.addEventListener("click",function(){
    //     console.log("wrap被点击");
    // },false);

    // sub.addEventListener("click",function(){
    //     console.log("sub被点击");
    // },false);

    // box.addEventListener("click",function(){
    //     console.log("box被点击");
    // },false);


    // 事件捕获
    wrap.addEventListener("click",function(){
        console.log("wrap被点击");
    },true);

    sub.addEventListener("click",function(){
        console.log("sub被点击");
    },true);

    box.addEventListener("click",function(){
        console.log("box被点击");
    },true);
</script>
</html>